## ECE 2560 Introduction to Microcontroller-Based Systems



## 程序代写代做 CS编程辅导

# Description 22 Line 22 Line 22 Line 22 Line 22



# Joke of the Day



## 柱庁代与代欧 CS 编柱辅导

Why do programn 5

r dark mode?

Because light attr

WeChat: cstutores

Email: tutores@163.com

QQ: 749389476

https://tutorcs.com



# Interrupts



## 程序代写代做 CS编程辅导

What is an embedded system without interrupts?

Interrupts are a very effect of fficient way to deal with event that are asynchronous with the

- User input: e.g., through buttons
- Input from sensors: e.g. value: cstutorcs
- Timers: e.g., start of the next symbol in a communication system Assignment Project Exam Help

The alternative to using interrupts tist periodic of 3constant polling

OQ: 749389476 wasteful

In many embedded system applications the MCU is idle (often in low power mode) waiting for interrupts

# Recap: Interrupt Handling 1



## 程序代写代做 CS编程辅导

#### What happens when an interrupt flag is raised?

- CPU completes execu
   rent instruction
- Program Counter PC i program Counter P
- Status Register **SR** is **The State** to the stack
- SR is cleared



## Assignment Project Exam Help

Email: tutorcs@163.comes disabled

Further interrupts disabled

- The highest priority interrupt is selected ...
- ... its Interrupt Service Routine (ISR) is identified from the Interrupt Vector Table (IVT) ... https://ammersscopponsibility to fill the IVT
- ... address of the ISR is loaded into the PC
- CPU starts executing the ISR There is no explicit call to an ISR

# Recap: Interrupt Handling 2



## 程序代与代做 CS编程辅导

#### **CPU starts executing the ISR**

- Unlike a subroutine, a not have input or output
- It can change global vata is can use the stack
- If the ISR is using the as to clean up the stack before reti
- Many interrupts are multi-sourced e.g., both S1 and S2 trigger a flag in P1IFG and are served Wellowstowns to the served wellows to the ser
- The ISR has to figure out which pin is implicated in the interrupt and perform the corresponding task. Project Exam Help
- The ISR must clear the interrupt flag it has served otherwise, interrupt flags are not cleared and there will be a continuous interrupt cycle

QQ: 749389476

#### Return from interrupt: reti

- Restores the Status Register from stack
- Restores the Program Counter from stack

#### Legend:

Black: Runtime does it

Blue: Programmer does it



程序代写代做 CS编程辅导

Interrupt Edge Select Register: PxIES

Bit PxIES.y selects the in graph of pin Px.y

Raising Edge

PxIES.y = 0: PxI s set on a low-to-high transition

PxIES.y = 1: PxIFG.y flag is set on a high-to-low transition

WeChat: cstutorcs

Falling Edge





程序代写代做 CS编程辅导

Interrupt Edge Select Register: PxIES

Bit PxIES.y selects the in pin Px.y

Reading the manual slau

NOTE: Writing to PxIES

Writing to P1IES or P2IES to reach Corresponding interrupt flags.

Axesignment Rroject Exame Help

 $\vec{E}$   $\vec{m}$  ail: tutor  $\vec{c}$  s @ 163.c  $\vec{o}$   $\vec{m}$  hanged

 $1 \rightarrow 0$  1 Will be set

... you see that writing to PxIES can result in an inadvertent interrupt flag

Not great! https://tutorcs.com

What to do? Select interrupt edge before enabling interrupts!

Also, clear interrupt flag after before next step



## 程序代写代做 CS编程辅导

Interrupt Enable Register: PxIE

Bit PxIE.y enables the Px rrupt flag associated with pin Px.y

PxIE.y = 0: Inter

Px.y is disabled

by default

PxIE.y = 1: Interrupt at pin Px.y is enabled

WeChat: cstutorcs

To enable interrupts for Px.y you need to set the bit PxIE.y Assignment Project Exam Help

You also need to enable general untersupts in the Status Register SR

Several ways to do this

eint

QQ: 749389476; enable general interrupts

bis.w #GIE, PRPS://tutorcs.compit in SR

BIT3, defined in header file



程序代写代做 CS编程辅导

Interrupt Flag Register: PxIFG

Bit PxIFG.y is the interrur sciated with pin Px.y

> **PxIFG.y = 0**: No ¦s pending at pin **Px.y**

> PxIFG.y = 1: An interrupt is pending at pin Px.y

WeChat: cstutorcs

If the interrupt

is enabled

PxIFG.y is set by transitions, not static levels of input Help Software, too, can set PxIFG.y to generate a software-initiated interrupt The ISR is responsible for the aring IPO IFG Where the interrupt Again, mind your order of writing to port configuration registers

NOTE:

PxIFG flags when changing PxOUT, PxDIR, or PxREN https://tutorcs.com
Writing to PxOUT, PxDIR, or PxREN can result in setting the corresponding PxIFG flags.

Clear interrupt flag after before enabling interrupts

# Populating the IVT



## 程序代写代做 CS编程辅导

slas789d.pdf

Table 6-4. Interrupt Sources, Flags, and Vectors (continued)

| INTERRUPT SOURCE              | T FLAG                                                                                                                                                               | SYSTEM<br>INTERRUPT | WORD<br>ADDRESS | PRIORITY |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------|----------|
| eUSCI_B1 receive or transmit) | UCB LIVING (SPI mode) UCB LIVING (SPI mode) LIACKIFG, UCSTTIFG, CTXIFG0, UCRXIFG1, CTXIFG2, UCRXIFG3, UCT LICBIT9IFG (I <sup>2</sup> C mode) (UCB1IV) <sup>(1)</sup> | Maskable            | 0FFE2h          |          |
| DMA                           | DMA0CTL.DMAIFG, DMA1CTL.DMAIFG, Wechalewcstutorcs                                                                                                                    | Maskable            | 0FFE0h          |          |
| Timer_A TA1                   | TA1CCR0.CCIFG                                                                                                                                                        | Maskable            | 0FFDEh          |          |
| Timer_A TA1                   | TA1CCR1.CCIFG to TA1CCR2.CCIFG. ASS1g1111011TF Projec                                                                                                                | t Exam F            | led poch        |          |
| I/O Port P1                   | P1IFG.0 to P1IFG.7<br>(P1IV) <sup>(1)</sup>                                                                                                                          | Maskable            | 0FFDAh          |          |
| Timer_A TA2                   | Emanacchilde CS @ 10                                                                                                                                                 | J. Gaskable         | 0FFD8h          |          |

For a port P1 interrupt, the word address for interrupt vector is 0xFFDA When P1 raises an interrupt flag, execution will switch to the label that is given in this address

We need to write the label of the **ISR** that serves port P1 to this address **How?** 

# Populating the IVT



## 程序代写代做 CS编程辅导

**How?** We will use assembler directives

We start by finding the weight is for interrupt vector: 0xFFDA

We locate the word address. Inker file "Ink\_msp430fr6989.cmd"

```
S main.asm
                                             S *main.asm
                    WeChatorestutones4, Length = UXUUUZ
       INI34
LOZ
                            : origin = 0xFFD6, length = 0x0002
104
       INT35
                            : origin = 0xFFD8, length = 0x0002
105
       INT36
106
       INT37
107
       INT38
       INT39
                            : origin = 0xFFDE, length = 0x0002
108
```

We add the label of the ISRNO the Internation with the end of \*.asm)

```
.sect "https://ttutorcs.ldentifies address 0xFFDA
.sect ".reset" Label of ISR
.short RESET
```